

FIG. 1



2/21

FIG. 2



FIG. 3



4/21

## FIG. 4A

system IO\_Controller ~ 100

1(1)

```

/* BitString8 & 16 based on Bit_String from Z.105 */
syntype Cgroup = Integer constants 0:3 endsyntype;
syntype Cond = Integer constants 0:31 endsyntype;
syntype CtxNum = Integer constants 0:7 endsyntype;
syntype EventNum = Integer constants 0:7 endsyntype ;
syntype InstAddr = Integer constants 0:65535 endsyntype;
syntype Instruction = BitString16 endsyntype ;
syntype Offset = Integer constants -128:127 endsyntype;
syntype Vbase = Integer constants 0:1023 endsyntype;
/* Exported from Context_Controller */
remote asleep, csw, idle Boolean nodelay ;
remote context CtxNum nodelay ; /* running context */
remote events BitString8 nodelay ; /* C-group 01 */
remote nctx CtxNum nodelay ; /* next context */
remote mask BitString8 nodelay ; /* Event Mask reg */
/* Exported from Data_Path_and_Interface_Resources */
remote slice Natural nodelay ; /* inst cycles per bg slice */
remote ien Boolean nodelay ; /* true for execute cycles */

```

102

signal

```

AckEv(CtxNum,EventNum),
AckInst(EventNum),
BcInst(Cond,Offset), ClearCy(CtxNum),
ClearFG, CSaddr(InstAddr),
CSdata(Instruction), CsLoad(CtxNum),
CsStore(CtxNum),
Event(CtxNum,EventNum),
ExtEvent(CtxNum,EventNum), HfOsc,
HwReset, InitInst(CtxNum),
InitSeq(CtxNum), LfOsc,
LoadMask(BitString8), Mr, Mf,
Qr, Qf, Reset, SetCy(CtxNum),
SetFG, SignalInst(CtxNum,EventNum),
SkpInst(Cgroup,BitString8), Sleep,
VecInst(Vbase), Wait, Wake ;

```

104

TO FIG. 4B

FIG. 4B



6/21

FIG. 5



FIG. 6

7/21



8/21

## FIG. 7A1

process Event\_Prioritizer ~ 152

1(4)

```
dcl act BitString8 ;
dcl c#, curBg CtxNum ;
dcl e# EventNum ;
dcl evMask, evStatus
    Array(CtxNum, BitString8) ;
dcl fg BitString8 ;
dcl k, l, prev CtxNum ;
dcl sliceCount Natural ;
dcl val BitString8 ;
dcl waited BitString8 ;
```

250

```
signal ResetMark ;
signalset
    AckInst, ClearFG,
    Event, InitInst,
    LoadMask,
    Mr, Mf, Qr, Reset,
    ResetMark, SetFG,
    SignalInst, Sleep,
    Wait, Wake ;
```

251

```
imported ien Boolean ;
imported slice Natural ;

dcl exported asleep, csw, idle Boolean ;
dcl exported ctx as context CtxNum ;
dcl exported events, mask BitString8 ;
dcl exported nctx CtxNum ;
```

252

/\* This process handles signals that alter event state,  
context activation state, or execution state (sleep, idle).

While Running, events, Signal Instructions, and loading the  
Event Mask are handled at once; while Ack, Init, Sleep,  
Wait, and Set/Clear FG are held on the process input  
queue until Mr. At Mr of execute (ien=1) cycles, any  
queued instruction (max=1/cycle) is processed, the context  
number, event flags (C-group 1) and event mask values  
are updated to reflect a possible context switch, and the  
slice count is decremented if the running context is in  
background. At Qr the activity flags are updated, then the  
highest priority active (fg) context, or current/next (bg)  
context is selected for execution at the next Mr,  
performing a context switch or going idle, starting at Mf,  
as appropriate. \*/

253

TO FIG. 7A2

FIG. 7A2

9/21

FROM FIG. 7A1



10/21



TO FIG. 7B2

11/21

FIG. 7B2

FROM FIG. 7B1



FIG. 7C

12/21



FIG. 7D1

13/21



TO FIG. 7D2

14/21

FIG. 7D2

FROM FIG. 7D1



15/21

FIG. 8



16/21

FIG. 9



17/21

FIG. 10



18/21

FIG. 11

| <u>SKPx</u>                        | 0 | 0 | 1 | Test Operation | C-group |   | Mask Value                                               |
|------------------------------------|---|---|---|----------------|---------|---|----------------------------------------------------------|
| <u>SKP0</u> - skip if any bits = 1 | 0 | 0 | 0 | 0              | 0       | 0 | <u>AFLAG</u> - set flag values                           |
| <u>SKP1</u> - skip if all bits = 0 | 0 | 0 | 1 | 0              | 1       |   | <u>EVENTS</u> - activation events (pre-Event Mask) ~ 608 |
| <u>SKP2</u> - skip if all bits = 1 | 0 | 1 | 0 | 1              | 0       |   | <u>DBL0</u> - low-order byte of data bus                 |
| <u>SKP3</u> - skip if both 0s & 1s | 0 | 1 | 1 | 1              | 1       |   | <u>DBH1</u> - high-order byte of data bus                |
| <u>SKP4</u> - skip if Cgroup=Mask  | 1 | 1 | 0 |                |         |   |                                                          |

  

| <u>VECTOR</u> | 0   | 0   | 1   | 1   | 1   |     | Vector Base (address bits 16:7) |
|---------------|-----|-----|-----|-----|-----|-----|---------------------------------|
| 610           | 602 | 612 | 613 | 603 | 604 | 605 |                                 |

  

| <u>SIGNAL</u> | 1   | 1   | 1   | 1   | 1 | 0 | Event Number | Context Number |
|---------------|-----|-----|-----|-----|---|---|--------------|----------------|
| 620           | 622 | 623 | 624 | 625 |   |   |              |                |

  

| <u>ACK</u> | 1   | 1   | 1   | 1   | 1 | 0 | not used | Event Number |
|------------|-----|-----|-----|-----|---|---|----------|--------------|
| 630        | 632 | 642 | 644 | 645 |   |   |          |              |

  

| <u>INIT</u> | 1   | 1   | 1   | 1   | 1   | 0   | not used | Context Number |
|-------------|-----|-----|-----|-----|-----|-----|----------|----------------|
| 640         | 642 | 652 | 654 | 655 | 656 | 657 |          |                |

  

| <u>STROBE</u> | 1   | 1   | 1   | 1   | 1   | 1 | 0 | Control Function |
|---------------|-----|-----|-----|-----|-----|---|---|------------------|
| 650           | 652 | 654 | 655 | 656 | 657 |   |   |                  |

19/21

FIG. 12



20/21

*FIG. 13*

|       | Initialization Vectors          | CS Word ~ 678<br><u>Addr</u> |
|-------|---------------------------------|------------------------------|
| 670 ~ | Context 0 Initialization Vector | 0000                         |
| 671 ~ | Context 1 Initialization Vector | 0004                         |
| 672 ~ | Context 2 Initialization Vector | 0008                         |
| 673 ~ | Context 3 Initialization Vector | 000C                         |
| 674 ~ | Context 4 Initialization Vector | 0010                         |
| 675 ~ | Context 5 Initialization Vector | 0014                         |
| 676 ~ | Context 6 Initialization Vector | 0018                         |
| 677 ~ | Context 7 Initialization Vector | 001C                         |

21/21

FIG. 14

